



JC780 U. S. PTO

03/22/00

3-24-00 A

Please type a plus sign (+) inside this box [+]

PTO/SB/05 (12/97)

Approved for use through 09/30/00. OMB 0651-0032

Patent and Trademark Office: U.S. DEPARTMENT OF COMMERCE

Under the Paperwork Reduction Act of 1995, no persons are required to respond to a collection of information unless it displays a valid OMB control number.

**UTILITY PATENT APPLICATION TRANSMITTAL**

(Only for new nonprovisional applications under 37 CFR 1.53(b))

Attorney Docket No. 42390.P8265Total Pages 3First Named Inventor or Application Identifier Kevin X. ZhangExpress Mail Label No. EM170547621USJC539 U.S. PTO  
09/532411  
03/22/00**ADDRESS TO:** Assistant Commissioner for Patents  
Box Patent Application  
Washington, D. C. 20231**APPLICATION ELEMENTS**

See MPEP chapter 600 concerning utility patent application contents.

1.  Fee Transmittal Form  
(Submit an original, and a duplicate for fee processing)
2.  Specification (Total Pages 28)  
(preferred arrangement set forth below)
  - Descriptive Title of the Invention
  - Cross References to Related Applications
  - Statement Regarding Fed sponsored R & D
  - Reference to Microfiche Appendix
  - Background of the Invention
  - Brief Summary of the Invention
  - Brief Description of the Drawings (if filed)
  - Detailed Description
  - Claims
  - Abstract of the Disclosure
3.  Drawings(s) (35 USC 113) (Total Sheets 17)
4.  Oath or Declaration (Total Pages 5)
  - a.  Newly Executed (Original or Copy)
  - b.  Copy from a Prior Application (37 CFR 1.63(d))  
(for Continuation/Divisional with Box 17 completed) **(Note Box 5 below)**
  - i.  **DELETIONS OF INVENTOR(S)** Signed statement attached deleting inventor(s) named in the prior application, see 37 CFR 1.63(d)(2) and 1.33(b).
5.  Incorporation By Reference (useable if Box 4b is checked)  
The entire disclosure of the prior application, from which a copy of the oath or declaration is supplied under Box 4b, is considered as being part of the disclosure of the accompanying application and is hereby incorporated by reference therein.
6.  Microfiche Computer Program (Appendix)

7.  Nucleotide and/or Amino Acid Sequence Submission  
(if applicable, all necessary)  
a.  Computer Readable Copy  
b.  Paper Copy (identical to computer copy)  
c.  Statement verifying identity of above copies

**ACCOMPANYING APPLICATION PARTS**

8.  Assignment Papers (cover sheet & documents(s))  
9.  a. 37 CFR 3.73(b) Statement (where there is an assignee)  
     b. Power of Attorney  
10.  English Translation Document (if applicable)  
11.  a. Information Disclosure Statement (IDS)/PTO-1449  
     b. Copies of IDS Citations  
12.  Preliminary Amendment  
13.  Return Receipt Postcard (MPEP 503) (Should be specifically itemized)  
14.  a. Small Entity Statement(s)  
     b. Statement filed in prior application, Status still proper and desired  
15.  Certified Copy of Priority Document(s) (if foreign priority is claimed)  
16.  Other: \_\_\_\_\_  
\_\_\_\_\_  
\_\_\_\_\_

17. If a **CONTINUING APPLICATION**, check appropriate box and supply the requisite information:

Continuation  Divisional  Continuation-in-part (CIP)  
of prior application No: \_\_\_\_\_

18. **Correspondence Address**

Customer Number or Bar Code Label

(Insert Customer No. or Attach Bar Code Label here)

or

Correspondence Address Below

NAME Michael J. Mallie Reg. No. 36,591

BLAKELY, SOKOLOFF, TAYLOR & ZAFMAN LLP

ADDRESS 12400 Wilshire Boulevard

Seventh Floor

CITY Los Angeles STATE California ZIP CODE 90025-1026

Country U.S.A. TELEPHONE (408) 720-8598 FAX (408) 720-9397

Respectfully submitted,

BLAKELY, SOKOLOFF, TAYLOR & ZAFMAN LLP

Dated: 3/2, 2000

Michael J. Mallie  
Reg. No. 36,591

**EXPRESS MAIL CERTIFICATE OF MAILING**

“Express Mail” mailing label number: EM170547621US

Date of Deposit: March 22, 2000

I hereby certify that I am causing this paper or fee to be deposited with the United States Postal Service "Express Mail Post Office to Addressee" service on the date indicated above and that this paper or fee has been addressed to the Assistant Commissioner for Patents, Washington, D. C. 20231

Sharon M. Osofsky

(Typed or printed name of person mailing paper or fee)

(Signature of person mailing paper or fee)

---

(Date signed)

UNITED STATES PATENT APPLICATION

FOR

**SHARED CACHE WORDLINE DECODER FOR REDUNDANT AND REGULAR  
ADDRESSES**

INVENTORS:

KEVIN X. ZHANG

PREPARED BY:

BLAKELY, SOKOLOFF, TAYLOR & ZAFMAN LLP  
12400 WILSHIRE BOULEVARD  
SEVENTH FLOOR  
LOS ANGELES, CA 90025-1026

(408) 720-8598

**EXPRESS MAIL CERTIFICATE OF MAILING**

"Express Mail" mailing label number EM170547621US

Date of Deposit March 22, 2000

I hereby certify that I am causing this paper or fee to be deposited with the United States Postal Service "Express Mail Post Office to Addressee" service under 37 CFR 1.10 on the date indicated above and is addressed to the Commissioner of Patents and Trademarks, Washington, D.C. 20231

Sharon M. Osofsky  
(Typed or printed name of person mailing paper or fee)

  
(Signature of person mailing paper or fee)

3-22-00

Date

**SHARED CACHE WORDLINE DECODER FOR BOTH REDUNDANT AND  
REGULAR ADDRESSES**

**FIELD OF THE INVENTION**

5        This invention relates generally to decoders for memory, and in particular to decoders for high-speed cache memory.

**BACKGROUND OF THE INVENTION**

A cache is a fast memory for storing copies of frequently accessed data. As  
10      processors become faster, cache access time is often a dominating factor in system performance. Conflicting goals face designers of cache memory systems. Smaller caches provide faster access times, but larger caches provide higher hit ratios, thereby reducing penalties associated with accessing slower memory.

15      Since a current trend in processor design is to devote a substantial proportion of chip area to cache memory, much effort has been invested in improving access times for large caches.

One prior art method shown in, for example, U.S. Patent No. 5,532,947 combines an adder for generating an effective address with a word-line  
20      decoder. This combined decoder/adder is shown in Figure 1. Another prior art method shown in, for example, U.S. Patent No. 5,860,092 combines an adder with a pre-decoder circuit to provide an input to a word-line driver. Figures 2

shows this prior art method. One disadvantage with these two methods is that carry propagation for larger addresses can adversely affect cache access time.

In another prior art method, Cortadella et al (in "Evaluation of A+B=K Conditions Without Carry Propagation," IEEE Transactions on Computers, vol.

5 41, pp. 1484-1488, Nov., 1992) show that an equality test does not require carry propagation. One representation of a sum A+B, which is suitable for use in a carry nonpropagative equality test, is known as half-adder or carry-sum form. The carry-sum representation uses a carry bit,  $C_i$ , and a sum bit,  $S_i$ , to represent a binary digit of a number in the  $i$ th digit position. In carry-sum form  
10 each number may have multiple valid representations. In a system of numbers, where each number is assigned multiple binary representations, the numbers are said to be in redundant form.

Current processors make use of pipelining to reduce cycle times and exploit parallelism within instruction streams. In order to make pipelining efficient,  
15 results from digital arithmetic circuitry are bypassed back to circuit inputs as operands for the next operation in a pipeline. This technique is preferred over one of waiting until results are written back to a register file, and it provides for higher utilization of a pipeline's parallelism. Since quickly loading operands from memory is critical to the performance of a processor, it may be desirable to  
20 bypass results of address computations to a load/store unit in order to reduce any delays associated with the load.

When bypassed addresses are used to access cache it is desirable to have a cache that can decode addresses in redundant form. When address calculations have time to complete, the addresses are already converted to a unsigned binary number and so a traditional decoder is desirable. Often, a

5 design decision must be made to store all addresses to one or the other form because two decoders require too much in area resources.

## BRIEF DESCRIPTION OF THE DRAWINGS

The present invention is illustrated by way of example and not limitation in the figures of the accompanying drawings.

**Figure 1** shows a prior art adder/decoder.

5       **Figure 2** shows another prior art adder/decoder.

**Figure 3** shows a carry-save adder circuit.

**Figure 4a** shows a ROM implementation of a 3:2 compressor or counter based on the truth table for addition in a carry-sum redundant form.

**Figure 4b** shows a half adder circuit, which can be used as a building

10      block to construct a full adder circuit.

**Figure 4c** shows a 3:2 compressor or counter that can be used to form the basic building block of a carry-save adder.

**Figure 5** shows a cache wordline decoder for decoding addresses in a carry-sum redundant form.

15      **Figure 6** shows one embodiment of a pre-decoder component circuit that accepts addresses in a carry-sum redundant form.

**Figure 7** shows another embodiment of a pre-decoder component circuit that accepts addresses in a negated carry-sum redundant form.

20      **Figure 8** shows one embodiment of a decoder component circuit that combines two-bit subsequences into three-bit subsequences.

**Figure 9** details one embodiment of a cache wordline decoder for decoding four-digit addresses in a carry-sum redundant form.

Figure 10a shows one embodiment of a circuit for selectively replacing one redundant representation bit with a constant bit for addresses in a redundant form.

Figure 10b shows another embodiment of a circuit for selectively 5 replacing one redundant representation bit with a constant bit for addresses in a negated redundant form.

Figure 11 shows another embodiment of a pre-decoder component circuit that accepts addresses in a carry-sum redundant form and provides selective replacement of one redundant representation bit vector with a

10 constant bit vector.

Figure 12 shows one embodiment of a cache wordline decoder for carry-sum redundant load addresses and unsigned binary store addresses that provides selective replacement of one redundant representation bit vector with a constant bit vector.

15 Figure 13a shows one embodiment of circuit that accepts addresses in a sign-digit redundant form and provides addresses in a negated carry-sum redundant form.

Figure 13b shows of circuit that accepts addresses in a sign-digit redundant form, provides selective replacement of one redundant 20 representation bit vector with a constant bit vector and provides addresses in a negated carry-sum redundant form.

**Figure 14** shows another embodiment of a pre-decoder component circuit that accepts addresses in a sign-digit redundant form and provides selective replacement of one redundant representation bit vector with a constant bit vector.

5       **Figure 15** shows another embodiment of a cache wordline decoder for sign-digit redundant load addresses and unsigned binary store addresses that provides selective replacement of one redundant representation bit vector with a constant bit vector.

**Figure 16** shows one embodiment of a digital computing system comprising a cache wordline decoder for redundant load addresses and unsigned binary store addresses that provides selective replacement of one redundant representation bit vector with a constant bit vector.

**Figure 17** shows one embodiment of a method of cache wordline decoding for redundant addresses or unsigned binary addresses using selective replacement of one redundant representation bit vector with a constant bit vector.

## DETAILED DESCRIPTION

These and other embodiments of the present invention may be realized in accordance with the following teachings and it should be evident that various modifications and changes may be made in the following teachings without

- 5 departing from the broader spirit and scope of the invention. The specification and drawings are, accordingly, to be regarded in an illustrative rather than restrictive sense and the invention measured only in terms of the claims.

In one embodiment, a cache wordline decoder, herein described, provides pre-decode circuitry to identify subsequences from redundant addresses and

- 10 can be configured to also identify subsequences from unsigned binary addresses for decoding into identified wordline sequences. The wordline sequences are used to access data stored in cache memory at corresponding storage locations. Since data in memory requested by a load operation is desired more urgently than result data needs to be written back into memory, a
- 15 disclosed embodiment of a cache wordline decoder provides a way to process load requests without waiting for load address calculations to be completed. But since store address calculations typically have time to finish, this embodiment of a cache wordline decoder provides a way to process store requests without requiring a second wordline decoder for unsigned binary
- 20 addresses.

One method for quickly calculating load addresses is to use a carry nonpropagative arithmetic circuit such as a carry-save adder to sum addressing

components, possibly including a base address and an index or a displacement. Results from a carry-save adder can be bypassed to a load-store unit in redundant form, without waiting for carry propagation to complete.

A carry save adder is shown in Figure 3. The carry save adder has a

- 5 structure very similar to that of a traditional adder except for eliminating the need to propagate carry signals generated in a first stage, 301, along the length of the result in a second stage, 302. When adding two of these numbers together, circuits, 303, which are similar to traditional half adders and 3:2 compressors can be used. Figure 4a shows a truth table for the 3:2
- 10 compressor, which could be implemented in a read-only memory (ROM). Figure 4b shows the traditional half adder circuit, and Figure 4c shows a 3:2 compressor circuit that can be used to form the basic building block, 303, of a carry save adder.

In order to access cache using such an address, a cache wordline decoder

- 15 for decoding addresses in a carry-sum redundant form is required. The type of cache wordline decoder required is depicted in Figure 5. It accepts addresses in which the binary digits comprise carry bits,  $C_i$ , and sum bits,  $S_i$ , produced by a carry-save adder. In order to identify a corresponding wordline, Wordline<sup>i</sup>, in cache memory, adjacent digits can first be pre-decoded by pre-decoder 501 to
- 20 identify possible subsequences that could result from completion of carry propagation. According to the identified possible subsequences, subsequence indicators in subsequence indicator sets 502, 503, 504, and 505, 506 are

activated. These subsequence indicators are combined in decoder 507 to identify a unique wordline sequence. According to the wordline sequence identified, one of a set of wordline indicators 508 is activated to access a corresponding location in cache.

- 5      Identification of possible subsequences from carry-sum redundant digits can be accomplished using a circuit like the one shown in Figure 6. This embodiment of a pre-decoder component circuit 608 comprises pre-decoder component circuit 604 and pre-decoder component circuit 602. Pre-decoder component circuit 604 accepts, sum bits,  $S_i$  and  $S_{i-1}$ , and carry bits,  $C_{i-1}$  and  $C_{i-2}$ ,
- 10     of an address in carry-sum redundant form and identifies possible two-bit subsequences that could result at positions,  $i$  and  $i-1$  when the carry-sum address is converted into two's complement form. The identified possible subsequences are indicated by activating at least one of the four possible subsequence indicator signals,  $R_i^{11}$ ,  $R_i^{01}$ ,  $R_i^{10}$  and  $R_i^{00}$ . Likewise, sum bits,  $S_{i-1}$
- 15     and  $S_{i-2}$ , and carry bits,  $C_{i-2}$  and  $C_{i-3}$ , can be used by pre-decoder component circuit 602 to identify possible two-bit subsequences that could result at positions,  $i-1$  and  $i-2$  when the address is converted to two's complement. The possible subsequences are indicated by activating at least one of the four possible subsequence indicator signals,  $R_{i-1}^{11}$ ,  $R_{i-1}^{01}$ ,  $R_{i-1}^{10}$ ,  $R_{i-1}^{00}$ .
- 20     As shown in Figure 6, the afore mentioned possible subsequence indicator signals (as shown in pre-decoder component circuit 604) for a subsequence

with most significant bit at position,  $i$ , in a wordline sequence are activated according to the following logic equations or their equivalents:

$$R_i^{11} = (S_{i-1} \text{ AND } C_{i-2}) \text{ XOR } (S_i \text{ XOR } C_{i-1}),$$

$$R_i^{01} = (S_{i-1} \text{ AND } C_{i-2}) \text{ XNOR } (S_i \text{ XOR } C_{i-1}),$$

5             $R_i^{10} = (S_{i-1} \text{ OR } C_{i-2}) \text{ XOR } (S_i \text{ XOR } C_{i-1}),$

$$R_i^{00} = (S_{i-1} \text{ OR } C_{i-2}) \text{ XNOR } (S_i \text{ XOR } C_{i-1}).$$

Another embodiment of a circuit for identification of possible subsequences from negated carry-sum redundant digits is shown in Figure 7. This

embodiment of a pre-decoder component circuit 708 comprises pre-decoder

10            component circuit 704 and pre-decoder component circuit 702. Pre-decoder component circuit 704 accepts, negated sum bits, not  $S_i$  and not  $S_{i-1}$ , and negated carry bits, not  $C_{i-1}$  and not  $C_{i-2}$ , of an address in carry-sum redundant form and identifies possible two-bit subsequences that could result at positions,  $i$  and  $i-1$  when the carry-sum address is converted into unsigned binary form.

15            The identified possible subsequences are indicated by activating at least one of the four signals,  $R_i^{11}$ ,  $R_i^{01}$ ,  $R_i^{10}$  and  $R_i^{00}$ . Likewise, negated sum bits, not  $S_{i-1}$  and not  $S_{i-2}$ , and negated carry bits, not  $C_{i-2}$  and not  $C_{i-3}$ , can be used by pre-decoder component circuit 702 to identify possible two-bit subsequences that could result at positions,  $i-1$  and  $i-2$  when the address is converted to unsigned

20            binary. The possible subsequences are indicated by activating at least one of the four signals,  $R_{i-1}^{11}$ ,  $R_{i-1}^{01}$ ,  $R_{i-1}^{10}$ ,  $R_{i-1}^{00}$ .

As shown in Figure 7, the afore mentioned possible subsequence indicator signals (as shown in pre-decoder component circuit 704) for a subsequence with most significant bit at position, i, in a wordline sequence are activated according to the following logic equations or their equivalents:

- 5  $R_i^{11} = (\text{NOT } S_{i-1} \text{ NOR NOT } C_{i-2}) \text{ XOR } (\text{NOT } S_i \text{ XOR NOT } C_{i-1}),$
- $R_i^{01} = (\text{NOT } S_{i-1} \text{ NOR NOT } C_{i-2}) \text{ XNOR } (\text{NOT } S_i \text{ XOR NOT } C_{i-1}),$
- $R_i^{10} = (\text{NOT } S_{i-1} \text{ NAND NOT } C_{i-2}) \text{ XOR } (\text{NOT } S_i \text{ XOR NOT } C_{i-1}),$
- $R_i^{00} = (\text{NOT } S_{i-1} \text{ NAND NOT } C_{i-2}) \text{ XNOR } (\text{NOT } S_i \text{ XOR NOT } C_{i-1}).$

The possible three-bit subsequences ending at position, i, can be identified

- 10 by combining possible two-bit sequences ending at position, i, with the possible two-bit subsequences ending at position, i-1. Figure 8 shows one embodiment of a decoder component circuit that combines two-bit subsequences into three-bit subsequences in this manner. It should be noted, of course, that one skilled in the art could modify the pre-decoders illustrated in Figures 6 and 7 to directly
- 15 identify possible three-bit subsequences, or to identify possible four-bit subsequences, or to identify possible subsequences of any other size.

As shown in Figure 8, a 3-bit possible subsequence indicator for a subsequence with most significant bit at position, i, in a wordline sequence is activated according to the following logic equations or their equivalents:

- 20  $R_i^{111} = R_i^{11} \text{ AND } R_{i-1}^{11},$
- $R_i^{110} = R_i^{11} \text{ AND } R_{i-1}^{10},$
- $R_i^{101} = R_i^{10} \text{ AND } R_{i-1}^{01},$

$$R_i^{100} = R_i^{10} \text{ AND } R_{i-1}^{00},$$

$$R_i^{011} = R_i^{01} \text{ AND } R_{i-1}^{11},$$

$$R_i^{010} = R_i^{01} \text{ AND } R_{i-1}^{10},$$

$$R_i^{001} = R_i^{00} \text{ AND } R_{i-1}^{01}, \text{ and}$$

5                     $R_i^{000} = R_i^{00} \text{ AND } R_{i-1}^{00}.$

In a like manner, longer subsequences could be identified by ANDing together additional subsequences.

One embodiment of a cache wordline decoder for decoding four-digit binary addresses in a carry-sum redundant form is illustrated in Figure 9. Through

10 combining the possible two-bit subsequences ending at position, i, identified by pre-decoder component circuit 908; position i-1, identified by pre-decoder component circuit 904; and position i-2, identified by pre-decoder component circuit 902; position with the one-bit possibilities for the least significant position, identified by pre-decoder component circuit 901 the unique four-bit wordline

15 corresponding to the carry-sum redundant address can be identified without requiring carry propagation.

A unique wordline indicator for a 4-bit wordline sequence is activated by decoder 916 according to the following logic equations or their equivalents:

$$\text{Word}^{1111} = R_3^{11} \text{ AND } R_2^{11} \text{ AND } R_1^{11} \text{ AND } R_0^{1X},$$

20                     $\text{Word}^{1110} = R_3^{11} \text{ AND } R_2^{11} \text{ AND } R_1^{10} \text{ AND } R_0^{0X},$

$$\text{Word}^{1101} = R_3^{11} \text{ AND } R_2^{10} \text{ AND } R_1^{01} \text{ AND } R_0^{1X},$$

$$\text{Word}^{1100} = R_3^{11} \text{ AND } R_2^{10} \text{ AND } R_1^{00} \text{ AND } R_0^{0X},$$

Word<sup>1011</sup> = R<sub>3</sub><sup>10</sup> AND R<sub>2</sub><sup>01</sup> AND R<sub>1</sub><sup>11</sup> AND R<sub>0</sub><sup>1X</sup>,

Word<sup>1010</sup> = R<sub>3</sub><sup>10</sup> AND R<sub>2</sub><sup>01</sup> AND R<sub>1</sub><sup>10</sup> AND R<sub>0</sub><sup>0X</sup>,

Word<sup>1001</sup> = R<sub>3</sub><sup>10</sup> AND R<sub>2</sub><sup>00</sup> AND R<sub>1</sub><sup>01</sup> AND R<sub>0</sub><sup>1X</sup>,

Word<sup>1000</sup> = R<sub>3</sub><sup>10</sup> AND R<sub>2</sub><sup>00</sup> AND R<sub>1</sub><sup>00</sup> AND R<sub>0</sub><sup>0X</sup>,

5 Word<sup>0111</sup> = R<sub>3</sub><sup>01</sup> AND R<sub>2</sub><sup>11</sup> AND R<sub>1</sub><sup>11</sup> AND R<sub>0</sub><sup>1X</sup>,

Word<sup>0110</sup> = R<sub>3</sub><sup>01</sup> AND R<sub>2</sub><sup>11</sup> AND R<sub>1</sub><sup>10</sup> AND R<sub>0</sub><sup>0X</sup>,

Word<sup>0101</sup> = R<sub>3</sub><sup>01</sup> AND R<sub>2</sub><sup>10</sup> AND R<sub>1</sub><sup>01</sup> AND R<sub>0</sub><sup>1X</sup>,

Word<sup>0100</sup> = R<sub>3</sub><sup>01</sup> AND R<sub>2</sub><sup>10</sup> AND R<sub>1</sub><sup>00</sup> AND R<sub>0</sub><sup>0X</sup>,

10 Word<sup>0011</sup> = R<sub>3</sub><sup>00</sup> AND R<sub>2</sub><sup>01</sup> AND R<sub>1</sub><sup>11</sup> AND R<sub>0</sub><sup>1X</sup>,

Word<sup>0010</sup> = R<sub>3</sub><sup>00</sup> AND R<sub>2</sub><sup>01</sup> AND R<sub>1</sub><sup>10</sup> AND R<sub>0</sub><sup>0X</sup>,

Word<sup>0001</sup> = R<sub>3</sub><sup>00</sup> AND R<sub>2</sub><sup>00</sup> AND R<sub>1</sub><sup>01</sup> AND R<sub>0</sub><sup>1X</sup>, and

Word<sup>0000</sup> = R<sub>3</sub><sup>00</sup> AND R<sub>2</sub><sup>00</sup> AND R<sub>1</sub><sup>00</sup> AND R<sub>0</sub><sup>0X</sup>.

In Figure 10a, one embodiment of a circuit for selectively replacing 1010 one bit of a bit vector of an address in redundant form with a constant bit is

15 illustrated. When redundant enable, REN, is asserted, a signal C<sub>i</sub> will propagate through the NAND structure 1011 and the inverter 1013 to produce C<sub>i</sub> at the output. When REN is negated, a constant low logic level will be produced.

In Figure 10b, another embodiment of a circuit for selectively replacing one

20 bit of an address in negated redundant form with a constant bit is illustrated. When low active redundant enable, REN bar, is asserted, an input signal, not

$C_i$ , will propagate through the NOR structure 1020 to produce  $C_i$  at the output.

When REN bar is high, a constant low logic level will be produced.

The circuit of Figure 10a can be used in a pre-decode component circuit to replace the carry bit vector with a constant bit vector. Figure 11 shows an

- 5 embodiment of a pre-decoder component circuit that accepts an address in a carry-sum redundant form and provides selective replacement of the carry bit vector with a constant bit vector. By selecting the correct constant, an address in unsigned binary form can be accepted as the sum bit vector and the resulting cache wordline decoder can be used for either redundant addresses or
- 10 unsigned binary addresses. For example, if redundant enable signal, REN, is asserted on select input 1101, then the carry signal  $C_{i-3}$  on bit vector input 1102 propagates through the AND structure 1110 undergoing two inversions to input 1104 of the pre-decode component circuit 1112 where it is combined with  $S_{i-2}$  on bit vector input 1105,  $S_{i-1}$  on bit vector input 1107, and similarly processed
- 15  $C_{i-2}$  at the bit vector replacement output 1606. On the other hand, if redundant enable signal, REN, is low on select input 1101, then the carry signal  $C_{i-3}$  on bit vector input 1102 does not propagate through the AND structure 1110, but rather the low value of REN propagates a zero to input 1104 of the pre-decode component circuit 1112 where it is combined with  $S_{i-2}$  on bit vector input 1105,  $S_{i-1}$  on bit vector input 1107, and a similarly produced zero at the bit vector replacement output 1606.
- 20

One embodiment of a cache wordline decoder for carry-sum redundant load addresses represented by a sum bit vector, S, and a carry bit vector, C, or unsigned binary store addresses represented by the linear bit vector, A, is depicted in Figure 12. Pre-decode circuitry 1201 provides selective

- 5 replacement of the carry bit vector with a constant bit vector, responsive to negation of a redundant enable control signal, REN. The decoding is then allowed to proceed as usual. In order to identify a corresponding wordline, Wordline<sup>1</sup>, in cache memory, adjacent digits can first be pre-decoded by pre-decoder 1201 to identify possible subsequences that could result from
- 10 completion of carry propagation. According to the identified possible subsequences, subsequence indicators in subsequence indicator sets 1202, 1203, 1204, and 1205, 1206 are activated. These subsequence indicators are combined in decoder 1207 to identify a unique wordline sequence. According to the wordline sequence identified, one of a set of wordline indicators 1208 is
- 15 activated to access a corresponding location in cache.

Another redundant representation used to quickly calculate load addresses without carry propagation is the sign-digit redundant form. In the sign-digit redundant form, each digit is represented by sign bit,  $X_{si}$ , and a magnitude bit,  $X_{mi}$ . Figure 13a shows one embodiment of circuit that accepts addresses in a sign-digit redundant form and produces addresses in a negated carry-sum redundant form. A least significant digit 1311 is produced by negating  $X_{m0}$  to produce a negated sum bit,  $S_0$  bar, while  $X_{s0}$  and  $X_{m0}$  are combined through an

AND gate to produce  $C_0$  bar. Other digits, including a most significant digit 1319 are produced by propagating each  $X_{mi}$  to produce each negated sum bit,  $S_i$  bar, while NOT  $X_{si}$  and  $X_{mi}$  are combined through a NAND gate to produce  $C_i$  bar.

Figure 13b shows another embodiment of a bit vector selection or bit vector replacement circuit including, a least significant digit replacement circuit 1321 and a most significant replacement circuit 1329, that accepts addresses in a sign-digit redundant form and provides selective replacement of the sign bit vector with a constant bit vector producing addresses in a negated carry-sum redundant form. Combining this circuit with the pre-decode component circuit 10 depicted in Figure 7 produces the embodiment illustrated in Figure 14.

In Figure 14, a pre-decoder component circuit that accepts addresses in a sign-digit redundant form provides selective replacement of the sign bit vector with a constant bit vector. By selecting the correct constant, an address in unsigned binary form can be accepted as the magnitude bit vector and the 15 resulting cache wordline decoder can be used for either redundant addresses or unsigned binary addresses.

One embodiment of a cache wordline decoder for sign-digit redundant load addresses represented by a sign bit vector,  $X_s$ , and a magnitude bit vector,  $X_m$ , or unsigned binary store addresses represented by the linear bit vector,  $A$ , is 20 depicted in Figure 15. Pre-decode circuitry 1501 provides selective replacement of the sign bit vector with a constant bit vector, responsive to negation of a redundant enable control signal, REN. The decoding is again

allowed to proceed as usual. In order to identify a corresponding wordline, Wordline<sup>1</sup>, in cache memory, adjacent digits can first be pre-decoded by pre-decoder 1501 to identify possible subsequences that could result from completion of carry propagation. According to the identified possible

5 subsequences, subsequence indicators in subsequence indicator sets 1502, 1503, 1504, and 1505, 1506 are activated. These subsequence indicators are combined in decoder 1507 to identify a unique wordline sequence. According to the wordline sequence identified, one of a set of wordline indicators 1508 is activated to access a corresponding location in cache.

10 One embodiment of a digital computing system is shown in Figure 16, which comprises a cache wordline decoder, 1611, for receiving redundant load addresses and unsigned binary store addresses. In one embodiment, cache 1611, is the fastest cache in a hierarchical plurality of caches including slower external caches and 1611 is resident on the same die as processor, 1610. In 15 another embodiment, cache 1611 and possibly other internal caches reside on the same die, but there are no external caches.

Instruction decoder, 1601, receives instructions that may include additions, loads, stores, etc. For example, an first instruction to add a base address in a first register to an index in a second register, writing the result in a third register

20 may be received and decoded. Then a second instruction to load data from the address in the third register may be received and decoded. The first instruction may produce a result by providing operands from a register file, 1605, to a

redundant adder, 1603. In order to complete the second instruction quickly, the result produced by redundant adder, 1603, may be bypassed to a cache, 1611, by the bypassing control 1607. Control unit, 1602, asserts redundant enable (REN) to direct pre-decoder, 1609, to handle the address in redundant form.

- 5        On the other hand, a third instruction to store a new result back to the address location found in the third register may be received. In this case the result produced by redundant adder, 1603, in the first instruction may have already been converted to unsigned binary form by redundant conversion unit, 1604, and written into register file, 1605. Therefore the contents of the third
- 10      register are sent to the cache, 1611, and control unit, 1602, negates REN to direct the pre-decoder, 1609, to provide selective replacement of one redundant representation bit vector with a constant bit vector, thereby correctly decoding the unsigned binary address received.

In Figure 17 one embodiment of a method of wordline decoding for

- 15      redundant addresses or unsigned binary addresses in a cache is illustrated. After receiving an address comprising a first bit vector and a second bit vector, 1701, at the cache, a check is performed to determine if redundant addressing is enabled, 1702. If it is enabled, subsequences of the first bit vector are combined, 1704, with subsequences of the second bit vector to identify possible
- 20      result subsequences. The result subsequences are then combined, 1705, to identify the unique wordline represented by the redundant address, and data stored at the identified wordline is accessed, 1706.

On the other hand, if redundant addressing is not enabled, 1702, then a selective replacement, 1703, of one redundant representation bit vector with a constant bit vector is performed. Subsequences of the original bit vector and the replaced bit vector are then combined, 1704, as before to identify possible 5 result subsequences. Finally, these result subsequences are then combined, 1705, to identify the unique wordline represented by the redundant address, and data stored at the identified wordline is accessed, 1706.

The above description is intended to illustrate preferred embodiments of the present invention. From the discussion above it should also be apparent that 10 the invention can be modified in arrangement and detail by those skilled in the art without departing from the principles of the present invention within the scope of the accompanying claims.

## CLAIMS

What is claimed is:

- 1 1. An apparatus for accessing data in a memory, the apparatus comprising:
  - 2 a bit vector replacement circuit to receive a first bit vector and a control
  - 3 signal and to substitute a constant bit vector for the first bit vector, in
  - 4 response to the control signal being in a first state, to produce a second bit
  - 5 vector;
  - 6 a pre-decoder coupled with the bit vector replacement circuit to receive a
  - 7 plurality of bit vectors including the second bit vector, to combine
  - 8 subsequences from the plurality of bit vectors to identify possible wordline
  - 9 subsequences corresponding to the plurality of bit vectors, and to activate a
  - 10 subsequence indicator for an identified possible wordline subsequence; and
  - 11 a wordline decoder coupled with the pre-decoder to combine activated
  - 12 subsequence indicators to identify a unique wordline corresponding to the
  - 13 plurality of bit vectors.

- 1 2. The apparatus of Claim 1, wherein the plurality of bit vectors correspond to
- 2 an address represented in carry-sum redundant form.

- 1 3. The apparatus of Claim 1, wherein the plurality of bit vectors comprise:
  - 2 a carry bit vector including a carry bit corresponding to a binary digit of
  - 3 the address; and

4           a sum bit vector including a sum bit corresponding to a binary digit of the  
5           address.

1    4. The apparatus of Claim 3, wherein the first bit vector is the carry bit vector.

1    5. The apparatus of Claim 4, wherein the second bit vector produced by the bit  
2           vector replacement circuit in response to the control signal being in a  
3           second state corresponds to the carry bit vector.

1    6. The apparatus of Claim 1, wherein the plurality of bit vectors correspond to  
2           an address represented in sign-digit redundant form.

1    7. The apparatus of Claim 6, wherein the plurality of bit vectors comprise:  
2           a sign bit vector including a sign bit corresponding to a binary digit of the  
3           address; and  
4           a magnitude bit vector including a magnitude bit corresponding to a  
5           binary digit of the address.

1    8. The apparatus of Claim 7, wherein the first bit vector is the sign bit vector.

1 9. The apparatus of Claim 8, wherein the second bit vector produced by the bit  
2 vector replacement circuit in response to the control signal being in a  
3 second state corresponds to the sign bit vector.

1 10. The apparatus of Claim 1, wherein the vector replacement circuit substitutes  
2 a constant bit vector corresponding to a zero vector for the first bit vector.

1 11. The apparatus of Claim 1, wherein the pre-decoder is a carry  
2 nonpropagative circuit.

1 12. The apparatus of Claim 11, wherein the pre-decoder identifies possible two-  
2 bit wordline subsequences.

1 13. The apparatus of Claim 11, wherein the pre-decoder activates a  
2 subsequence indicator for an identified possible two-bit subsequence.

1 14. The apparatus of Claim 1, wherein one of the plurality of bit vectors  
2 corresponds to an address represented in unsigned binary form.

1 15. The apparatus of Claim 14, wherein said one of the plurality of bit vectors  
2 corresponds to a store address.

1 16. The apparatus of Claim 1, further comprising:

2       a cache coupled with the wordline decoder to store a copy of a datum

3       stored in the memory, the copy being stored at a wordline in the cache

4       corresponding to an address in the memory.

1 17. The apparatus of Claim 16, further comprising:

2       a processor coupled with the pre-decoder to produce the plurality of bit

3       vectors.

1 18. The apparatus of Claim 17, wherein the processor produces one or more of

2       the plurality of bit vectors by adding together addressing components

3       including a base address and an index or a displacement.

1 19. A digital computing system comprising:

2       a die;

3       a bit vector selection circuit on the die to receive a first bit vector and a

4       control signal, and to select a constant bit vector or the first bit vector

5       responsive to the control signal, and to output the selected bit vector as a

6       second bit vector;

7       a decoder circuit on the die coupled to the bit vector selection circuit to

8       receive a plurality of bit vectors including the second bit vector and to

9       combine a subsequence from each of the plurality of bit vectors to identify a

10 wordline corresponding to the plurality of bit vectors;

11 an internal cache on the die, the internal cache coupled with the decoder

12 circuit to store a first datum at the wordline corresponding to the plurality of

13 bit vectors;

14 a processor on the die coupled with the decoder circuit to produce the

15 plurality of bit vectors; and

16 an external cache, not on the die, to store a second datum, the external

17 cache coupled with the die and with the internal cache, to transmit the

18 second datum to the internal cache to be stored on the die.

1 20. The digital computing system of Claim 19, wherein the plurality of bit

2 vectors correspond to an address represented in carry-sum redundant form

3 and the plurality of bit vectors comprise:

4 a carry bit vector including a carry bit corresponding to a binary digit of

5 the address; and

6 a sum bit vector including a sum bit corresponding to a binary digit of the

7 address.

1 21. The digital computing system of Claim 20, wherein the first bit vector is the

2 carry bit vector.

1    22. The digital computing system of Claim 19, wherein one of the plurality of bit  
2    vectors corresponds to an address represented in unsigned binary form.

1    23. The apparatus of Claim 22, wherein said one of the plurality of bit vectors  
2    corresponds to a store address.

1    24. A cache memory system comprising:  
2        a plurality of lines for storing copies of memory storage locations having  
3        corresponding addresses;  
4        means for decoding an address to access a line of the cache memory  
5        system responsive to an access request that includes an address  
6        represented in a redundant form; and  
7        means for decoding an address to access a line of the cache memory  
8        system responsive to an access request that includes an address  
9        represented in unsigned binary form.

1    25. A method of accessing data in a first storage, the method comprising:  
2        copying a plurality of storage locations from a second storage into a  
3        plurality of lines of the first storage by asserting corresponding line signals;  
4        receiving an access request including a first bit vector, a second bit vector  
5        and a control signal;  
6        setting the second bit vector equal to a constant bit vector if the control

7 signal is in a first state;  
8 identifying a line corresponding to the combined first bit vector and second  
9 bit vector;  
10 asserting the identified line signal; and  
11 accessing the line of the first storage corresponding to the asserted line  
12 signal.

## **ABSTRACT OF THE DISCLOSURE**

In one embodiment, a wordline decoder provides access to cache memory locations when addresses are bypassed directly from arithmetic circuitry in redundant form. The wordline decoder is also designed to provide access to cache memory locations when addresses are received from registers in an unsigned binary form. The combined functionality is provided in a pre-decode circuit by selectively replacing one of a plurality of redundant bit vectors with a constant bit vector when redundant addressing is not enabled.

PRIOR ART  
FIG. 1



PRIOR ART  
FIG. 2



FIG. 3



FIG. 4a

| 3:2 Compressor     |                 |                  |
|--------------------|-----------------|------------------|
| <u>ROM Address</u> | <u>ROM Data</u> |                  |
| 0 0 0              | 0               | 0                |
| 0 0 1              | 0               | 1                |
| 0 1 0              | 0               | 1                |
| 0 1 1              | 1               | 0                |
| 1 0 0              | 0               | 1                |
| 1 0 1              | 1               | 0                |
| 1 1 0              | 1               | 0                |
| 1 1 1              | 1               | 1                |
| <b>A B C</b>       |                 | <b>Carry Sum</b> |



FIG. 4b

FIG. 4c



FIG. 5



FIG. 6



FIG. 7



FIG. 8



FIG. 9





FIG. 11



FIG. 12



FIG. 13a



FIG. 13b



FIG. 14



FIG. 15



FIG. 16



FIG. 17



**DECLARATION AND POWER OF ATTORNEY FOR PATENT APPLICATION**  
**(FOR INTEL CORPORATION PATENT APPLICATIONS)**

As a below named inventor, I hereby declare that:

My residence, post office address and citizenship are as stated below, next to my name.

I believe I am the original, first, and sole inventor (if only one name is listed below) or an original, first, and joint inventor (if plural names are listed below) of the subject matter which is claimed and for which a patent is sought on the invention entitled

"SHARED CACHE WOKDLINE DECODER FOR REDUNDANT AND REGULAR ADDRESSES"

the specification of which

X is attached hereto.  
— was filed on \_\_\_\_\_ as

United States Application Number \_\_\_\_\_  
or PCT International Application Number \_\_\_\_\_  
and was amended on \_\_\_\_\_  
(if applicable)

I hereby state that I have reviewed and understand the contents of the above-identified specification, including the claim(s), as amended by any amendment referred to above. I do not know and do not believe that the claimed invention was ever known or used in the United States of America before my invention thereof, or patented or described in any printed publication in any country before my invention thereof or more than one year prior to this application, that the same was not in public use or on sale in the United States of America more than one year prior to this application, and that the invention has not been patented or made the subject of an inventor's certificate issued before the date of this application in any country foreign to the United States of America on an application filed by me or my legal representatives or assigns more than twelve months (for a utility patent application) or six months (for a design patent application) prior to this application.

I acknowledge the duty to disclose all information known to me to be material to patentability as defined in Title 37, Code of Federal Regulations, Section 1.56.

I hereby claim foreign priority benefits under Title 35, United States Code, Section 119(a)-(d), of any foreign application(s) for patent or inventor's certificate listed below and have also identified below any foreign application for patent or inventor's certificate having a filing date before that of the application on which priority is claimed:

Prior Foreign Application(s)

Priority  
Claimed

| (Number) | (Country) | (Day/Month/Year Filed) | Yes | No |
|----------|-----------|------------------------|-----|----|
|          |           |                        | Yes | No |
|          |           |                        | Yes | No |

I hereby claim the benefit under Title 35, United States Code, Section 119(e) of any United States provisional application(s) listed below:

| Application Number | Filing Date |
|--------------------|-------------|
|                    |             |

I hereby claim the benefit under Title 35, United States Code, Section 120 of any United States application(s) listed below and, insofar as the subject matter of each of the claims of this application is not disclosed in the prior United States application in the manner provided by the first paragraph of Title 35, United States Code, Section 112, I acknowledge the duty to disclose all information known to me to be material to patentability as defined in Title 37, Code of Federal Regulations, Section 1.56 which became available between the filing date of the prior application and the national or PCT international filing date of this application:

| Application Number | Filing Date | Status -- patented,<br>pending, abandoned |
|--------------------|-------------|-------------------------------------------|
|                    |             |                                           |

I hereby appoint the persons listed on Appendix A hereto (which is incorporated by reference and a part of this document) as my respective patent attorneys and patent agents, with full power of substitution and revocation, to prosecute this application and to transact all business in the Patent and Trademark Office connected herewith.

Send correspondence to Michael J. Mallie, BLAKELY, SOKOLOFF, TAYLOR & (Name of Attorney or Agent)  
ZAFMAN LLP, 12400 Wilshire Boulevard 7th Floor, Los Angeles, California 90025 and direct telephone calls to Michael J. Mallie, (408) 720-8300. (Name of Attorney or Agent)

I hereby declare that all statements made herein of my own knowledge are true and that all statements made on information and belief are believed to be true; and further that these statements were made with the knowledge that willful false statements and the like so made are punishable by fine or imprisonment, or both, under Section 1001 of Title 18 of the United States Code and that such willful false statements may jeopardize the validity of the application or any patent issued thereon.

Full Name of Sole/First Inventor Kevin X. Zhang

Inventor's Signature \_\_\_\_\_ Date \_\_\_\_\_

Residence Portland, Oregon Citizenship P.R. China  
(City, State) (Country)

Post Office Address 14258 NW Tradewind St.  
Portland, Oregon 97229

Full Name of Second/Joint Inventor \_\_\_\_\_

Inventor's Signature \_\_\_\_\_ Date \_\_\_\_\_

Residence \_\_\_\_\_ Citizenship \_\_\_\_\_  
(City, State) (Country)

Post Office Address \_\_\_\_\_

Full Name of Third/Joint Inventor \_\_\_\_\_

Inventor's Signature \_\_\_\_\_ Date \_\_\_\_\_

Residence \_\_\_\_\_ Citizenship \_\_\_\_\_  
(City, State) (Country)

Post Office Address \_\_\_\_\_

## APPENDIX A

William E. Alford, Reg. No. 37,764; Farzad E. Amini, Reg. No. P42,261; Aloysius T. C. AuYeung, Reg. No. 35,432; William Thomas Babbitt, Reg. No. 39,591; Carol F. Barry, Reg. No. 41,600; Jordan Michael Becker, Reg. No. 39,602; Bradley J. Bereznak, Reg. No. 33,474; Michael A. Bernadicou, Reg. No. 35,934; Roger W. Blakely, Jr., Reg. No. 25,831; Gregory D. Caldwell, Reg. No. 39,926; Ronald C. Card, Reg. No. 44,587; Andrew C. Chen, Reg. No. 43,544; Thomas M. Coester, Reg. No. 39,637; Alin Corie, Reg. No. P46,244; Dennis M. deGuzman, Reg. No. 41,702; Stephen M. De Clerk, under 37 C.F.R. § 10.9(b); Michael Anthony DeSanctis, Reg. No. 39,957; Daniel M. De Vos, Reg. No. 37,813; Robert Andrew Diehl, Reg. No. 40,992; Sanjeet Dutta, Reg. No. P46,145; Matthew C. Fagan, Reg. No. 37,542; Tarek N. Fahmi, Reg. No. 41,402; Paramita Ghosh, Reg. No. 42,806; James Y. Go, Reg. No. 40,621; James A. Henry, Reg. No. 41,064; Willmore F. Holbrow III, Reg. No. P41,845; Sheryl Sue Holloway, Reg. No. 37,850; George W Hoover II, Reg. No. 32,992; Eric S. Hyman, Reg. No. 30,139; William W. Kidd, Reg. No. 31,772; Sang Hui Kim, Reg. No. 40,450; Eric T. King, Reg. No. 44,188; Erica W. Kuo, Reg. No. 42,775; Kurt P. Leyendecker, Reg. No. 42,799; Michael J. Mallie, Reg. No. 36,591; Andre L. Marais, under 37 C.F.R. § 10.9(b); Paul A. Mendonsa, Reg. No. 42,879; Darren J. Milliken, Reg. 42,004; Lisa A. Norris, Reg. No. 44,976; Chun M. Ng, Reg. No. 36,878; Thien T. Nguyen, Reg. No. 43,835; Thinh V. Nguyen, Reg. No. 42,034; Dennis A. Nicholls, Reg. No. 42,036; Daniel E. Ovanezian, Reg. No. 41,236; Marina Portnova, Reg. No. P45,750; Babak Redjaian, Reg. No. 42,096; William F. Ryann, Reg. 44,313; James H. Salter, Reg. No. 35,668; William W. Schaal, Reg. No. 39,018; James C. Scheller, Reg. No. 31,195; Jeffrey Sam Smith, Reg. No. 39,377; Maria McCormack Sobrino, Reg. No. 31,639; Stanley W. Sokoloff, Reg. No. 25,128; Judith A. Szepesi, Reg. No. 39,393; Vincent P. Tassinari, Reg. No. 42,179; Edwin H. Taylor, Reg. No. 25,129; John F. Travis, Reg. No. 43,203; George G. C. Tseng, Reg. No. 41,355; Joseph A. Twarowski, Reg. No. 42,191; Lester J. Vincent, Reg. No. 31,460; Glenn E. Von Tersch, Reg. No. 41,364; John Patrick Ward, Reg. No. 40,216; Mark L. Watson, Reg. No. P46,322; Thomas C. Webster, Reg. No. P46,154; Charles T. J. Weigell, Reg. No. 43,398; Kirk D. Williams, Reg. No. 42,229; James M. Wu, Reg. No. 45,241; Steven D. Yates, Reg. No. 42,242; and Norman Zafman, Reg. No. 26,250; my patent attorneys, and Justin M. Dillon, Reg. No. 42,486; my patent agent, of BLAKELY, SOKOLOFF, TAYLOR & ZAFMAN LLP, with offices located at 12400 Wilshire Boulevard, 7th Floor, Los Angeles, California 90025, telephone (310) 207-3800, and Alan K. Aldous, Reg. No. 31,905; Robert D. Anderson, Reg. No. 33,826; Joseph R. Bond, Reg. No. 36,458; Richard C. Calderwood, Reg. No. 35,468; Jeffrey S. Draeger, Reg. No. 41,000; Cynthia Thomas Faatz, Reg. No. 39,973; Sean Fitzgerald, Reg. No. 32,027; John N. Greaves, Reg. No. 40,362; Seth Z. Kalson, Reg. No. 40,670; David J. Kaplan, Reg. No. 41,105; Charles A. Mirho, Reg. No. 41,199; Leo V. Novakoski, Reg. No. 37,198; Naomi Obinata, Reg. No. 39,320; Thomas C. Reynolds, Reg. No. 32,488; Kenneth M. Seddon, Reg. No. 43,105; Mark Seeley, Reg. No. 32,299; Steven P. Skabrat, Reg. No. 36,279; Howard A. Skaist, Reg. No. 36,008; Steven C. Stewart, Reg. No. 33,555; Raymond J. Werner, Reg. No. 34,752; Robert G. Winkle, Reg. No. 37,474; and Charles K. Young, Reg. No. 39,435; my patent attorneys, and Thomas Raleigh Lane, Reg. No. 42,781; Calvin E. Wells; Reg. No. P43,256, Peter Lam, Reg. No. 44,855; and Gene I. Su, Reg. No. 45,140; my patent agents, of INTEL CORPORATION; and James R. Thein, Reg. No. 31,710, my patent attorney; with full power of substitution and revocation, to prosecute this application and to transact all business in the Patent and Trademark Office connected herewith.

## APPENDIX B

### Title 37, Code of Federal Regulations, Section 1.56 Duty to Disclose Information Material to Patentability

(a) A patent by its very nature is affected with a public interest. The public interest is best served, and the most effective patent examination occurs when, at the time an application is being examined, the Office is aware of and evaluates the teachings of all information material to patentability. Each individual associated with the filing and prosecution of a patent application has a duty of candor and good faith in dealing with the Office, which includes a duty to disclose to the Office all information known to that individual to be material to patentability as defined in this section. The duty to disclosure information exists with respect to each pending claim until the claim is cancelled or withdrawn from consideration, or the application becomes abandoned. Information material to the patentability of a claim that is cancelled or withdrawn from consideration need not be submitted if the information is not material to the patentability of any claim remaining under consideration in the application. There is no duty to submit information which is not material to the patentability of any existing claim. The duty to disclosure all information known to be material to patentability is deemed to be satisfied if all information known to be material to patentability of any claim issued in a patent was cited by the Office or submitted to the Office in the manner prescribed by §§1.97(b)-(d) and 1.98. However, no patent will be granted on an application in connection with which fraud on the Office was practiced or attempted or the duty of disclosure was violated through bad faith or intentional misconduct. The Office encourages applicants to carefully examine:

(1) Prior art cited in search reports of a foreign patent office in a counterpart application, and

(2) The closest information over which individuals associated with the filing or prosecution of a patent application believe any pending claim patentably defines, to make sure that any material information contained therein is disclosed to the Office.

(b) Under this section, information is material to patentability when it is not cumulative to information already of record or being made or record in the application, and

(1) It establishes, by itself or in combination with other information, a prima facie case of unpatentability of a claim; or

(2) It refutes, or is inconsistent with, a position the applicant takes in:

(i) Opposing an argument of unpatentability relied on by the Office, or

(ii) Asserting an argument of patentability.

A prima facie case of unpatentability is established when the information compels a conclusion that a claim is unpatentable under the preponderance of evidence, burden-of-proof standard, giving each term in the claim its broadest reasonable construction consistent with the specification, and before any consideration is given to evidence which may be submitted in an attempt to establish a contrary conclusion of patentability.

(c) Individuals associated with the filing or prosecution of a patent application within the meaning of this section are:

(1) Each inventor named in the application;

(2) Each attorney or agent who prepares or prosecutes the application; and

(3) Every other person who is substantively involved in the preparation or prosecution of the application and who is associated with the inventor, with the assignee or with anyone to whom there is an obligation to assign the application.

(d) Individuals other than the attorney, agent or inventor may comply with this section by disclosing information to the attorney, agent, or inventor.